Python多线程同步Lock、RLock、Semaphore、Event实例 您所在的位置:网站首页 python 线程间同步 Python多线程同步Lock、RLock、Semaphore、Event实例

Python多线程同步Lock、RLock、Semaphore、Event实例

#Python多线程同步Lock、RLock、Semaphore、Event实例| 来源: 网络整理| 查看: 265

一、多线程同步

由于CPython的python解释器在单线程模式下执行,所以导致python的多线程在很多的时候并不能很好地发挥多核cpu的资源。大部分情况都推荐使用多进程。

python的多线程的同步与其他语言基本相同,主要包含:

Lock & RLock :用来确保多线程多共享资源的访问。 Semaphore : 用来确保一定资源多线程访问时的上限,例如资源池。 Event : 是最简单的线程间通信的方式,一个线程可以发送信号,其他的线程接收到信号后执行操作。

二、实例

1)Lock & RLock

Lock对象的状态可以为locked和unlocked

使用acquire()设置为locked状态; 使用release()设置为unlocked状态。

如果当前的状态为unlocked,则acquire()会将状态改为locked然后立即返回。当状态为locked的时候,acquire()将被阻塞直到另一个线程中调用release()来将状态改为unlocked,然后acquire()才可以再次将状态置为locked。

Lock.acquire(blocking=True, timeout=-1),blocking参数表示是否阻塞当前线程等待,timeout表示阻塞时的等待时间 。如果成功地获得lock,则acquire()函数返回True,否则返回False,timeout超时时如果还没有获得lock仍然返回False。

实例:(确保只有一个线程可以访问共享资源)

复制代码 代码如下: import threading import time num = 0 lock = threading.Lock() def func(st): global num print (threading.currentThread().getName() + ' try to acquire the lock') if lock.acquire(): print (threading.currentThread().getName() + ' acquire the lock.' ) print (threading.currentThread().getName() +" :%s" % str(num) ) num += 1 time.sleep(st) print (threading.currentThread().getName() + ' release the lock.' ) lock.release() t1 = threading.Thread(target=func, args=(8,)) t2 = threading.Thread(target=func, args=(4,)) t3 = threading.Thread(target=func, args=(2,)) t1.start() t2.start() t3.start()

结果:

RLock与Lock的区别是:RLock中除了状态locked和unlocked外还记录了当前lock的owner和递归层数,使得RLock可以被同一个线程多次acquire()。

2)Semaphore

Semaphore管理一个内置的计数器, 每当调用acquire()时内置计数器-1; 调用release() 时内置计数器+1; 计数器不能小于0;当计数器为0时,acquire()将阻塞线程直到其他线程调用release()。

实例:(同时只有2个线程可以获得semaphore,即可以限制最大连接数为2):

复制代码 代码如下: import threading import time

semaphore = threading.Semaphore(2) def func(): if semaphore.acquire(): for i in range(5): print (threading.currentThread().getName() + ' get semaphore') semaphore.release() print (threading.currentThread().getName() + ' release semaphore') for i in range(4): t1 = threading.Thread(target=func) t1.start()

结果:

3) Event

Event内部包含了一个标志位,初始的时候为false。 可以使用使用set()来将其设置为true; 或者使用clear()将其从新设置为false; 可以使用is_set()来检查标志位的状态; 另一个最重要的函数就是wait(timeout=None),用来阻塞当前线程,直到event的内部标志位被设置为true或者timeout超时。如果内部标志位为true则wait()函数理解返回。

实例: (线程间相互通信)

复制代码 代码如下: import logging import threading import time

logging.basicConfig(level=logging.DEBUG, format="(%(threadName)-10s : %(message)s", )

def wait_for_event_timeout(e, t): """Wait t seconds and then timeout""" while not e.isSet(): logging.debug("wait_for_event_timeout starting") event_is_set = e.wait(t) logging.debug("event set: %s" % event_is_set) if event_is_set: logging.debug("processing event") else: logging.debug("doing other work") e = threading.Event() t2 = threading.Thread(name="nonblock", target=wait_for_event_timeout,args=(e, 2)) t2.start() logging.debug("Waiting before calling Event.set()") time.sleep(7) e.set() logging.debug("Event is set")

运行结果:

三、其他

1) 线程局部变量

线程局部变量的值是跟线程相关的,区别与全局的变量。使用非常简单如下:

复制代码 代码如下: mydata = threading.local() mydata.x = 1

2)对Lock,semaphore,condition等使用with关键字代替手动调用acquire()和release()。

微信分享php中文网直播班

声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系[email protected]核实处理。

相关标签:Python 多线程同步 Lock RLock Semaphore Event上一篇:python统计一个文本中重复行数的方法下一篇:python通过zlib实现压缩与解压字符串的方法

相关文章

相关视频

归纳整理三十个Python的实用技巧python列表和元组详解(实例详解)经典技巧之Python案例详解归纳整理!Python实用技巧总结Python多线程同步Lock、RLock、Sem...Python 简介Python 环境搭建Python 中文编码Python 基础语法Python 变量类型

网友评论

文明上网理性发言,请遵守 新闻评论服务协议

我要评论专题推荐独孤九贱-php全栈开发教程

全栈 170W+

主讲:Peter-Zhu 轻松幽默、简短易学,非常适合PHP学习入门

玉女心经-web前端开发教程

入门 80W+

主讲:灭绝师太 由浅入深、明快简洁,非常适合前端学习入门

天龙八部-实战开发教程

实战 120W+

主讲:西门大官人 思路清晰、严谨规范,适合有一定web编程基础学习

作者信息

php中文网

认证0级讲师

发布技术文章最新文章热门排行

归纳整理三十个Python的实用技巧python列表和元组详解(实例详解)经典技巧之Python案例详解归纳整理!Python实用技巧总结Python数据异常值检测和处理(实例详解)一起来分析Python函数式编程带你一起解读Python多线程Python学习之解析Flask运行原理(图文详解)

python是什么意思大数据专业学习什么内容python如何处理excel数据pycharm怎么安装py文件怎么打开?python中eval是什么意思?python里面def是什么意思python怎么换行输出推荐视频教程javascript初级视频教程javascript初级视频教程jquery 基础视频教程jquery 基础视频教程视频教程分类php视频教程html视频教程css视频教程JS视频教程jQuery视频教程mysql视频教程Linux视频教程Python视频教程网站首页 PHP视频PHP实战PHP代码PHP手册词条手记编程词典php培训

php中文网:公益在线php培训,帮助PHP学习者快速成长!

Copyright 2014-2021 https://www.php.cn/ All Rights Reserved | 苏ICP备2020058653号-1关于我们免责申明赞助与捐赠广告合作

  


【本文地址】

公司简介

联系我们

今日新闻

    推荐新闻

    专题文章
      CopyRight 2018-2019 实验室设备网 版权所有